-
Notifications
You must be signed in to change notification settings - Fork 1.7k
api: proxy: custom: Implement APIs for custom Go plugins #10299
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: master
Are you sure you want to change the base?
Conversation
… support OTel extensions * Remove needless Golang related files from the original sketch commit Signed-off-by: Rob Skillington <[email protected]> Signed-off-by: Hiroshi Hatake <[email protected]>
Signed-off-by: Hiroshi Hatake <[email protected]>
de56254
to
6d6dfcb
Compare
d201c70
to
e152ad2
Compare
Signed-off-by: Hiroshi Hatake <[email protected]>
e152ad2
to
8d4db49
Compare
Signed-off-by: Hiroshi Hatake <[email protected]>
6d54d88
to
2e9c39f
Compare
Signed-off-by: Hiroshi Hatake <[email protected]>
2e9c39f
to
a054862
Compare
plugin->context = ((struct flb_custom_instance *)proxy->instance)->context; | ||
|
||
ret = plugin->cb_init(plugin); | ||
if (ret <= 0) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why a 0
return value is considered an error ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is because FLB_ERROR
is defined as 0
in flb_macros.h here: https://github.com/fluent/fluent-bit/blob/master/include/fluent-bit/flb_macros.h#L29 which means we need to handle 0 as error, too.
Signed-off-by: Hiroshi Hatake <[email protected]>
For some motivations to support custom plugin mechanism in Fluent Bit, we need to implement custom plugins which are built on top of Golang infrastructures.
This PR makes to be able to provide and support Golang custom plugins.
This PR is based on #9470 but adding modifications with working on calyptia-plugin module which is maintained here:
chronosphereio/calyptia-plugin#101
Plus, we need to implement custom plugin mechanism calyptia-plugin modue.
So, I also implemented custom Golang mechanism in chronosphereio/calyptia-plugin#101.
Note that we might have to maintain ABI for plugin API like logging and obtaining cmetrics instances.
I just adding APIs for custom plugins afterwards of input or output API definitions.
Enter
[N/A]
in the box, if an item is not applicable to your change.Testing
Before we can approve your change; please submit the following in a comment:
If this is a change to packaging of containers or native binaries then please confirm it works for all targets.
ok-package-test
label to test for all targets (requires maintainer to do).Documentation
Backporting
Fluent Bit is licensed under Apache 2.0, by submitting this pull request I understand that this code will be released under the terms of that license.